APPARATUS AND METHOD FOR DIGITAL MULTIPLICATION 
USING REDUNDANT BINARY ARITHMETIC 



BACKGROUND OF THE INVENTION 

1 . Field of the Invention 

The present invention relates to a parallel multiplier, and more particularly, to 
an apparatus and method for digital multiplication adopting a redundant binary 
arithmetic technique to generate a partial product. 

2. Description of the Related Art 

With a recent trend toward system-on-a-chip (SoC), the functional blocks 
constituting an integrated circuit are being demanded to occupy a small area of 
hardware while having improved performances. A multiplier is representative of the 
functional blocks, and plays an important role in many high-performance 
microprocessors or signal processing chips. Hence, a technique of reducing the 
size of a multiplier while maintaining the performance thereof is required to conform 
with the SoC trend. 

In a multiplication arithmetic algorithm used in conventional multipliers, partial 
products are obtained using a modified booth's algorithm (MBA) and are added up 
by a carry-save adder having a structure such as a Wallace-tree, to thereby obtain a 
final multiplication result. This multiplication is usually achieved using a normal 
binary arithmetic. Here, the partial products can be summed up using a redundant 
binary arithmetic technique instead of a normal binary arithmetic technique. The 
characteristic of a redundant binary arithmetic that there is no continuous 
propagation of carry is the property of an adder required by a general arithmetic for 
summing up partial products. 

A conventional arithmetic method performed by a multiplier using a redundant 
binary arithmetic will now be described. In this method, first, partial products are 
produced from input values by a normal binary arithmetic operation using an MBA. 



A conventional multiplication method using the above-described MBA uses a 
radix-4 numeration system. That is, when numbers X and Y are multiplied, the 
number Y having m bits is expressed as in Equation 1 according to the MBA: 



.-(1) 



wherein Di corresponds to one among a group of values -2, -1, 0, 1 and 2, and is 
obtained by encoding three consecutive bits y i+2 , y i+1 and y, of the number Y by a 
calculation of -2-y i+2 + y i+1 + y^ Every three consecutive bits of the m bits of number 
Y are grouped and consecutive groups overlap by one bit such that the last bit of 



each group is the first bit of the following group, thus] — 3-bit groups are obtained, 



and thus the number m of partial products is reduced to | — + 1 1 . Here, Txl denotes 

the smallest integer among integers that are greater than x. The reason why +1 is 
added is that correction bits to be added to the least significant bit of each of the 
partial products due to the 2's complement arithmetic are collected and the collected 
result is considered as a single partial product. The method of grouping three bits to 
encode m-bit Y in the MBA system is illustrated in Equation 2: 
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Equation 2 is applied when m is an even number, and always adds '0' next to 
the least significant bit. In this case, since the MBA performs encoding using a 
radix-4, every three consecutive bits of the m bits of number Y are grouped and 
consecutive groups overlap by one bit such that the last bit of each group is the first 
bit of the following group, as shown in Equation 2. In a general case where the m- 
bit number Y is encoded in a 2 k radix numeration system, every k+1 consecutive bits 
of the m bits of number Y are grouped and consecutive groups overlap by one bit 
such that the last bit of each group is the first bit of the following group. Here, 



partial products formed in normal binary numbers are produced by multiplying Di by 
X. 

Next, the partial products formed in normal binary numbers are converted into 
partial products expressed in redundant binary numbers. That is, the sum of partial 
products A and B formed in normal binary numbers can be expressed as in Equation 
3: 

A+B = A-(-B)= A-(B+\)= (A-B)-l ...(3) 

Here, if a-b is defined to be (a,b), it can be seen from Equation 4 that -1 is 
equal to (0,1): 

A-B=(A,B) ...(4) 

wherein the right side represents the redundant binary number of the result of A+B 
arithmetic operation. In the right side of Equation 3, - 1 , which is finally added to the 
least significant bit, is a correction bit to be added by the 2's complement arithmetic 
operation. Here, -1 can be expressed in a redundant binary number (0,1). When 
Equation 3 is adopted in the addition of partial products formed in normal binary 
numbers, the sum of partial products formed in redundant binary numbers can be 
obtained by pairing many normal binary partial products and inverting one of two 
normal binary partial products. 

Consequently, when m-bit multiplication input values are multiplied by the 

M 

MBA, \— + 1 normal binary partial products are produced. Thus, r normal binary 

partial products are once summed while being converted into redundant binary 
numbers, resulting in the |~— j sum expressed in redundant binary numbers. 

These redundant binary numbers are summed by a redundant binary 
arithmetic operation on the basis of an addition rule as shown in Table 1 , thereby 
obtaining the final product of X and Y, the product appearing in a redundant binary 
form. 
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Table 1 denotes a rule of summing redundant binary numbers using a 
conventional arithmetic technique. In Table 1, (<7 ; + ,a~) and (b* ,b~) denote two 

redundant binary numbers intended to be added, and (s^,s~) represent 

an intermediate carry and an intermediate sum, respectively, which are expressed in 
5 redundant binary numbers, when two numbers are added, and "either denotes that 
it does not matter whether '0' or T is selected as h M . Also, h M denotes an 
intermediate parameter made to prevent continuous carry propagation. Values of 
(a* y a~) and (b* ,b~) when h; is 1 are bolded values. In the case of h,=1 , value -1 

can be possibly propagated as a carry. 
10 [Table 1] 



CASE 


( fl >;) 




(C + C~) (V 




(KA) 






1 


(0,0) (0,1) 
(1,0) 


either 


(0,0) (0,0) 




(0,0) (1,0) 
(0,1) 






2 


(0,1) (0,0) 


0 


(0,0) (0,1) 




(0,0) (0,1) 


1 


(0,1) (1,0) 


3 


(1.0) (0,0) 


0 


(1.0) (0,1) 




(0,0) (1,0) 


1 


(0,0) (1,0) 


4 


(0,1) 


either 


(0,1) (0,0) 




(0,1) 






5 


(1,0) 


either 


(1,0) (0,0) 




(1,0) 







Referring to Table 1 , an addition of two redundant binary numbers [ (a+ , a~ ) 
and (b*,b~) ] corresponds to one among the five cases described above. 
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In Case 1 that the sum of two redundant binary numbers is zero, both the 
intermediate carry and the intermediate sum are 0. In Case 2 that the sum of two 
redundant binary numbers is -1 , if there is a possibility that -1 is propagated from 
the next lower digit, that is, if hj is 1, the intermediate sum and the intermediate carry 
are 1 and -1, respectively, so that -1 is offset by the intermediate sum of 1 even if 
- 1 is propagated. Thus, the addition can be carried out without carry propagation. 
In Case 3 that the sum of two redundant binary numbers is 1 , if there is a possibility 
that 1 is propagated from the next lower digit, that is, if hj is 0, the intermediate sum 
and the intermediate carry are -1 and 1, respectively, so that 1 is offset by the 
intermediate sum of -1 even if 1 is propagated. Thus, the addition can be carried 
out without carry propagation. In Case 3, if hj is 1, there is a possibility that -1 is 
propagated from the next lower digit, so that the intermediate sum and the 
intermediate carry are 1 and 0, respectively. Thus, the value -1 is offset by the 
intermediate sum of 1 even if -1 is propagated, so that there is no further 
propagation of carry. In Case 4 that the sum of two redundant binary numbers is -2, 
and Case 5 that the sum is 2, there is no further propagation of carry, and the 
intermediate sum is 0, regardless of the value of carry to be propagated from the 
next lower digit. The intermediate carry for Case 4 is -1 , and the intermediate carry 
for Case 5 is 1 . When two redundant binary numbers are summed as shown in 
Table 1 , a case that both , a~ ) and (Z> ; + , b~ ) take the state (1 , 1 ) is excluded on 
the assumption that (1,1) has already been transformed to (0,0). The final sum 
(d* ,d~) of two redundant binary numbers according to the rule shown in Table 1 
can be expressed as in Equation 5: 

df = (st + c^M-si" + <£.,), d: = (s? + <£,)• (sr + c~^), 
dt = h i _ l )-(J~ l -k i _ l + l^-h^) 
d: = (/. e h t _ x ) ■ {J~ x ■ + /._! • h~ 2 ) 

if the radix of a number system used increases, the number of partial products 
further decreases. In general, when an 2 k radix is used, the number of partial 
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products decreases to — + 1 . In the case of the multiplication of m-bit numbers X 



and Y using a 2 k radix number system, the number Y is generally expressed as in 
Equation 6: 



wherein D i = y ki _ x + • 2 J 1 ) - y k{l+l) _ x ■ 2 k ~ l . In the case of a radix-4 



MBA, D, by which X is multiplied is a value selected from a group of values {-2, -1 , 
0, 1 , 2), so that a partial product becomes one among values {-2X, -X, 0, X, 2X}. 
The multiples of X can be simply obtained by left-shifting X, so that they place little 
burden on hardware. However, as the radix of a number system used increases, the 
burden on hardware increases. For example, in the case of a multiplication having 
a 2 k radix, D, has a value selected from a group of values {-2 k ~\ -2 k ~ 1 +1 , • • • , 0, • • • 
, 2 k1 - 1 , 2 k ~ 1 }. That is, the number of multiples of X that can be obtained by 
multiplying X by D,- is 2 k +1, and they are {-2 k " 1 X, (-2 k1 +1)X, • • • , OX, • • • , (2 k - 1 -1)X, 
2 k1 X}. For example, in the case of a radix-64, k is 6, and a total of 65 multiples of X 
are required. A multiple of X such as 2'X among the multiples can be simply 
obtained by left-shifting X by i bits. However, odd multiples of X such as (2'+1)X 
cannot be obtained by the left-shifting operation. That is, in order to obtain 3X, a 
separate addition operation such as X+2X is required. 

Consequently, when a multiplier using a redundant binary arithmetic performs 
a conventional arithmetic operation, the above-described separate arithmetic 
operation must be performed on each of the odd multiples of X. Therefore, the 
number of additional addition operations increases as the radix of a number system 
used for multiplication increases, so that a burden upon hardware increases. 

SUMMARY OF THE INVENTION 
To solve the above problem, an objective of the present invention is to 
provide a digital multiplication apparatus adopting a redundant binary arithmetic, by 

6 




• ••£>••• D X D 0 = D 



(6) 



which the amount of hardware required can be reduced by applying the redundant 
binary arithmetic to produce partial products. 

Another objective of the present invention is to provide a digital multiplication 
method performed by a digital multiplication apparatus adopting the redundant 
binary arithmetic. 

To achieve the first objective, the present invention provides a digital 
multiplication apparatus adopting a redundant binary arithmetic for multiplying two 
numbers X and Y using a radix-2k number system, the apparatus including: a data 
converter for data-converting the m-bit number Y into m/k-digit data D (= D^D,^ 
.... Dj ... DjD 0 ); a partial product calculator for converting each of the digits Di of the 
number Y converted by the data converter into a combination of the coefficients of a 
fundamental multiple, multiplying the combination by the number X, and outputting 
the product as a redundant binary partial product; a redundant binary adder for 
summing the partial products for all of the digits of the converted number Y; and a 
redundant binary (RB)-normal binary (NB) converter for converting the redundant 
binary sum into a normal binary number and outputting the converted normal binary 
sum as the product of the two numbers. 

To achieve the second objective, the present invention provides a digital 
multiplication method adopting a redundant binary arithmetic for multiplying two 
numbers X and Y using a radix-2k number system, the method including: (a) data- 
converting the m-bit number Y into m/k-digit data D (= D^D^ .... Dj ... D^q); (b) 
converting each of the digits Di of the number Y into a combination of the 
coefficients of a fundamental multiple, and multiplying the combination by the 
number X to obtain a redundant binary partial product; (c) summing the partial 
products for all of the digits of the number Y converted; and (d) converting the 
redundant binary sum into a normal binary number to obtain the product of the two 
numbers. 

BRIEF DESCRIPTION OF THE DRAWINGS 
The above objectives and advantage of the present invention will become 
more apparent by describing in detail a preferred embodiment thereof with reference 
to the attached drawings in which: 



FIG. 1 is a schematic block diagram of a digital multiplication apparatus 
adopting a redundant binary arithmetic, according to the present invention; 

FIG. 2 is a block diagram of a preferred embodiment of the partial product 
calculator shown in FIG. 1; 

FIG. 3 is a circuit diagram of a preferred embodiment of the present invention 
including one of the multiplexers shown in FIG. 2 and a logic combination unit for 
the selected multiplexer; 

FIG. 4 is a circuit diagram of a simplified adder according to a preferred 
embodiment of the present invention; 

FIG. 5 is a circuit diagram of an adder according to another preferred 
embodiment of the present invention; 

FIG. 6 is a flowchart illustrating a digital multiplication method according to 
the present invention; 

FIG. 7 is a flowchart for explaining the step of determining the coefficients of 
the fundamental multiples shown in FIG. 6; 

FIG. 8 is a flowchart for explaining a preferred embodiment of the step 152 
shown in FIG. 6; and 

FIG. 9 is a flowchart illustrating a preferred embodiment of the steps 152 
through 156 shown in FIG. 6, in a digital multiplication method adopting a redundant 
binary arithmetic according to the present invention. 

DESCRIPTION OF THE PREFERRED EMBODIMENT 
Referring to FIG. 1, a digital multiplication apparatus adopting a redundant 
binary arithmetic, according to the present invention, includes a data converter 1 0, a 
partial product calculator 12, a redundant binary adder 14 and a redundant binary- 
normal binary (RB-NB) converter 16. 

The digital multiplication apparatus shown in FIG. 1 multiplies two numbers X 
and Y using a radix-2 k number system. To achieve this, first, the data converter 10 
data-converts the number Y composed of m bits, for example, into m/k-digit data D 
as shown in Equation 6, and outputs the m/k-digit data D to the partial product 
calculator 12. 
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The partial product calculator 12 converts each digit Di of the data D output 
from the data converter 10 into a combination of the coefficients of fundamental 
multiples, multiplies the combination by the number X having a predetermined 
number of bits, and outputs the multiplied result as a partial product of a redundant 
binary form mentioned in the description of Equations 3 and 4 to the redundant 



binary adder 14. In the end, — + 1 partial products from the partial product 



The redundant binary adder 14 adds up — + 1 redundant binary partial 



products for all of the digits of the data D, which is the number Y data-converted by 
the data converter 10, and outputs the sum to the RB-NB converter 16. The RB-NB 
converter 16 converts the received RB sum into an NB sum, and outputs the NB 
sum as the result of a multiplication of the two numbers X and Y through an output 
terminal OUT. 

FIG. 2 is a block diagram of a preferred embodiment 12A of the partial 
product calculator 12 shown in FIG. 1. This embodiment includes a fundamental 
multiple determination unit 20, first through m/k multiplexers 30, 32, ... and 34, first 
through m/k logic combination units 40, 42, ... and 44, and a controller 50. 

The fundamental multiple determination unit 20 bit-divides the m-bit Y by re- 
encoding it, multiplies each divided bit group by a predetermined weighted value, 
determines the coefficients of fundamental multiples by summing the products, 
multiplies each of the determined coefficients of the fundamental multiples by X, and 
outputs the results to the first through m/k multiplexers 30, 32, ... and 34. Each of 
the multiplexers 30, 32,... and 34 selects two among e fundamental multiples output 
from the fundamental multiple determination unit 20 in response to a corresponding 
selection signal S1 , S2, ... or Sm/k and outputs the two selected results to the 
corresponding logic combination units 40, 42,... or 44. Here, two selected results 
output from each of the multiplexers 30, 32, ... and 34 are fundamental multiples. 
Each of the first through m/k logic combination units 40, 42, ... and 44 performs a 
logic combination on the two selected fundamental multiples and output the results 




calculator 12 are output to the redundant binary adder 14. 
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of the logic combination as redundant binary partial products to the redundant 
binary adder 14 through a corresponding output terminal OUT1, OUT2, ... or 
OUTm/k. The controller 50 receives a total of m/k digits of the data D into which the 
data converter 1 0 converts the number Y, via an input port IN, produces 
combinations of the fundamental multiples for each digit of the data D, and 
generates the selection signals S1, S2, ... and Sm/kfor allowing the multiplexers to 
select corresponding fundamental multiples, according to the produced 
combinations. 

In order to facilitate understanding of the present invention, the operations of 
the circuits shown in FIGS. 1 and 2 and preferred embodiments of the circuits will 
now be described on the assumption that k is 6. 

When two numbers X and Y are multiplied in a radix-64 number system, a 

total of 65 X multiples, that is, -32X, -31X 0 31X and 32X, are required. 

Here, the 65 multiples can be expressed as combinations of 9 (e=9) fundamental 
multiples such as 0, X, 2X, 3X, 4X, 8X, 16X, 24X and 32X according to the rule 
shown in Table 2 according to the present invention. A method of producing 
fundamental multiples will be described in detail later. 
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[Table 2] 



ninnXi (A,B) i extra bit 


n in n X i (A, B) i extra bit 


ninnXi (A.B) lextra bit 


ninnXi (A, B) iextra bit 


0 i O's.Vs i 0,0 


8 j 0's,8 | 0,1 


16 i O's.16 i 0,1 


24 jo's f 24| 0,1 


1 ! 1,Vs | 0,0 


9 i 1,8 | 0,1 


17 ! 1,16 ! 0,1 


25 ! 1,24 | 0,1 


2 ! 2,Vs | 0,0 


10 ! 2,8 | 0,1 


18 | 2,16 j 0,1 


26 | 2,24 ! 0,1 


3 | 3,1Js | 0,0 


11 | 3,8 j 0,1 


19 | 3,16 | 0,1 


27 | 3,24 | 0,1 


4 1 4,r§ j 0,0 


12 | 4,8 | 0,1 


20 | 4,16 | 0,1 


28 j 4,24 | 0,1 


** i 11 i o.o 


12* | 4,16 j 0,0 


20* | 1,24 | 0,0 


28* | 4,32 | 0.0 


5 | 3,8 j 0,0 


13 | 3,16 j 0,0 


21 | 3,24 | 0,0 


29 | 3,32 ] 0.0 


6 | 2,8 | 0,0 


14 | 2,16 | 0,0 


22 | 2,24 | 0,0 


30 | 2,32 ] 0,0 


7 | 1,8 j 0,0 


15 | 1,16 ] 0,0 


23 | 1,24 j 0,0 


31 | 1,32 j 0,0 


8 j (V§,B ! 0,0 


16 | jrs,16 j 0,0 


24 j (T_s,24 j 0,0 


32 j 0^,32 j 0,0 


ninnXi (A, B) jextra bit 


n in n X | (A,B) | extra bit 


n in n X j (A, B) {extra bit 


ninnX' (A, B) | extra bit 


0 j 1Js,0's | 0,0 


-8 ! 8,0's j 1,0 


-16 1 16,0's | 1,0 


-24 [24,0'sj 1,0 


-1 | I§.1 ! 0,0 


-9 | 8,1 j 1,0 


-17 | 16,1 j 1,0 


-25 | 24- 1 i 1,0 


-2 | Ls.2 ! 0,0 


-10 | 8,2 j 1,0 


-18 | 16,2 j 1,0 


-26 | 24,2 | 1,0 


-3 | Vs,3 | 0,0 


-11 | 8,3 | 1,0 


-19 | 16,3 j 1,0 


-27 | 24,3 j 1,0 


-4 | Vs,4 j 0,0 


-12 | 8,4 | 1,0 


-20 j 16,4 j 1,0 


-28 | 24,4 j 1,0 


-4* | 8,4 j 0,0 


-12* | 16,4 j 0,0 


-20* j £4,4 ] 0,0 


-28* j 32,4 j 0.0 


-5 j 8,3 J 0,0 


-13 j 16,3 j 0,0 


-21 j 24,3 j 0,0 


-29 | 32,3 I 0.0 


-6 1 8,2 1 0,0 


-14 | 16,2 ] 0,0 


-22 ] 24,2 ] 0,0 


-30 ] 32,2 j 0,0 


-7 j 8,1 | 0,0 


-15 | 16,1 ! o.o 


-23 ] 24,1 j 0,0 


-31 ] 32,1 j 0,0 


-8* t ^ j 0,0 


-16* 1 16,0^8 | 0,0 


-24* j 24,tfs j 0,0 


-32 J32,(r§| 0,0 



In Table 2, the coefficient (n) of a multiple denotes Di, X at A and B is omitted 
for convenience' sake, underlined multiples denote multiples, the bits of which are 
5 all inverted, and O's or 1 's denotes the case that all of the bits are O or 1 . However, 
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an extra bit, each number of which is one bit, means correction bits EX + and EX 
generated due to the 2's complement arithmetic. 

X multiples formed in normal binary numbers can be converted into 
redundant binary multiples formed of only combinations of some normal binary 
fundamental multiples by a rule as shown in Table 2. For example, a process for 
expressing -20X in a redundant binary number is shown in Equation 7: 

-20X= - \6X- 4X = (16X + \)-4X 

(7) 

= (16X- AX) + 1 ee (\6X,4X) + (1,0) 

For example, as can be seen from Equation 7, (\6X,4X) is the redundant binary 

form in which -20X that is a normal binary partial product is expressed, and (1 ,0), 
which is an extra bit, is correction bits produced due to the 2's complement 
arithmetic. In an example of a radix-64, only 3X among 9 fundamental multiples 
requires a separate addition arithmetic. That is, 24X can be obtained by left-shifting 
3X by 3 bits, and the remaining X fundamental multiples can be obtained by left- 
shifting X by an appropriate number of bits. However, 3X needs a separate addition 
arithmetic of adding X and 2X. 

In Table 2, the digits A and B of the redundant binary form of nX, n of which is 
negative, can be obtained simply by transposing the two digits A and B of the 
redundant binary form of nX, n of which is positive. Also, it can be seen from the 
form (A,B) of nX, n of which is positive, that all of the bits of a multiple for B are 
inverted, bits of A in the preceding five rows are not inverted, and bits of A in the 
next five rows are all inverted. In the case of nX, n of which is negative, it can be 
seen that, if each digit A is transposed with each digit B, the same rule as described 
above is established. Also, it can be seen from Table 2 that, in the case of nX, n of 
which is positive, the same fundamental multiples are used for B in every five rows, 
and a pattern of fundamental multiples used for A is repeated in every ten rows. If 
using the facts that, in the case of nX, n of which is negative, the corresponding (A, 
B) is obtained by transposing the two digits A and B of nX, n of which is positive, 
and all of the bits of a multiple for B are inverted, the digits A and B can be 
summarized as in Table 3, which is a truth table for making a partial product 
expressed in a redundant binary form. 
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In Table 3, A^, B Di , Aj and B t denote the bits of B D , A and B, respectively, 
N is a parameter representing whether a multiple of X is negative (1 ) or positive (0), 
l A is a parameter representing whether a multiple to be allocated to A is to be 
inverted (1) or not (0), and Aq and B D are intermediate parameters described later. 
For example, if n is 1 1 in Table 2, N is 0 because n is positive, and l A is 0 because A 
is 3X. However, in the case of -22X, N is 1 because n is negative, and l A is 1 
because A is an inverted form of 24. Ao and B D are fundamental multiples selected 
among 9 fundamental multiples to express a normal binary multiple in the form of a 
redundant binary multiple. These intermediate parameters Ad and B D are 
processed, thereby obtaining the final values A and B. For example, in the case of 
13X shown in Table 2, Ad and B D are 3X and 16X, respectively, and N and l A are 0 
and 1, respectively, whereby A and B are finally 3X and \6X , respectively. Also, 
in the case of -10X shown in Table 2, Aq and B D are 2X and 8X, respectively, and N 
and l A are 1 and 0, respectively, whereby A and B are finally an inverted value of 8X, 
and 2X, respectively. 



[Table 3] 



N 


Ia 




B Di 


A, 


B, 


0 


0 


0 


0 


0 


1 


0 


0 


0 


1 


0 


0 


0 


0 


1 


0 


1 


1 


0 


0 


1 


1 


1 


0 


0 


1 


0 


0 


1 


1 


0 


1 


0 


1 


1 


0 


0 


1 


1 


0 


0 


1 


0 


1 


1 


1 


0 


0 




0 


0 


0 


1 


0 




0 


0 


1 


1 


1 




0 


1 


0 


0 


0 




0 


1 


1 


0 


1 




1 


0 


0 


0 


0 




1 


0 


1 


0 


1 
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1 


1 


1 


0 


1 


0 


1 


1 


1 


1 


1 


1 



In Table 2, in case of n being 4, 8, 12, 16, 20, 24, 28, -4, -8, -12, -16, -20, 
-24 and -28, even though they are the same normal binary multiples, they are 
expressed in different redundant binary numbers. Table 3 can be expressed in 
logical expression such as Equation 8: 

4 = (N® I A )® A Dl , B t = (N © B Dl ) ...(8) 

The structure and operation of a preferred embodiment of the present 
invention, which performs Equation 8, will now be described referring to FIG. 3. 
FIG. 3 is a circuit diagram of a preferred embodiment of the present invention 
including one among the multiplexers shown in FIG. 2 and a logic combination unit 
corresponding to the selected multiplexer. This embodiment includes a multiplexer 
60 and a logic combination unit 70. 

Referring to FIG. 3, the multiplexer 60 is made up of first through tenth NMOS 
transistors MN1 through MN10. Each of the transistors has a gate connected to a 
corresponding selection signal S1X, S2X, S3X, S4X, ZERO, S8X, S16X, S24X, 
S32X or ONE, and a source and a drain connected between a fundamental multiple 
X, 2X, 3X, 4X, VSS, VDD, 32X, 24X, 16X or 8X, which is a corresponding partial 
product among partial products obtained by multiplying the coefficients of 
fundamental multiples by X, and the logic combination unit 70. The logic 
combination unit 70 includes a first in/erter 72 for inverting one of the partial 
products selected by the multiplexer 60, a second inverter 76 for inverting the other 
selected partial product, a first exclusive OR unit 74 for exclusively performing OR 

operation on the output A Dl of the first inverter 72 and the third bit y 6j+2 from the 

least significant bit y flJ _ 1 of Y ( ■ - ■ y 6j+5 y 6j+4 y^ y 6j+2 y 6j+1 y 6j y 6M ■ • • ), and a second 

exclusive OR unit 78 for exclusively performing OR operation on the output B Dl of 

the second inverter 76 and the most significant bit y 6j+5 . In FIG. 3, d* and d~ are 

the bit Aj of A and the bit Bj of B in Table 2, respectively, y 6j+2 is Nel A in Equation 8, 
and y 6j+5 is N in Equation 8. 
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To be more specific, the multiplexer 60 of FIG. 3 includes two 5-to-1 
multiplexers (MUXes) each made up of 5 n-type MOS transistors at the right or left 
side. The multiplexer 60 receives SnX as a selection signal and selects an input nX. 
The coefficients (n) of fundamental multiples are 1, 2, 3, 4, 8, 16, 24 and 32, the left 
MUX receives the bits of X, 2X, 3X, 4X and VSS, and the right MUX receives the 
bits of 8X, 16X, 24X, 32X and VDD. VSS and VDD are logic values 0 and 1 , 
respectively, and the selection signals of MUXes which select these input values 
VSS and VDD are ZERO and ONE, respectively. A^ and B Dj are the outputs of the 
5-to-1 MUXes, and J ; + and d~ , which are an i-th pair of a normal binary multiple 

expressed in a redundant binary multiple form (A, B), are A; and Bj in Equation 8, 
respectively. 

In FIG. 3, as well as being output to the redundant binary adder 14 without 
change, andd~ can be output to the redundant binary adder 14 after being 
transformed, respectively, as shown in Equation 9: 

-(9) 

If a redundant binary multiple is output after being transformed as shown in 
Equation 9, hardware for summing up redundant binary partial products to be 
described later can be simplified. In order to achieve this, as shown in FIG. 3, the 
logic combination unit 70 can further include a first inversion OR unit 80 for 
performing inversion OR on the outputs of the first and second exclusive OR units 
74 and 78, a first AND unit 82 for performing AND operation on the outputs of the 
first and second exclusive OR units 74 and 78, and a second inversion OR unit 84 
for performing inversion OR on the output of the first AND 82 and the output of the 
first inversion OR unit 80. 

The addition of two redundant binary partial products by the redundant binary 
adder 14 will now be described. Redundant binary partial products (# ; + ,ct~ ) and 

(b* y b~) obtained by the circuit shown in FIG. 3 are summed according to the rule 

of Table 4 according to the present invention. 
[Table 4] 
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case 








1 


(0,0) (1,1) (0,1) (1,1) (0,0) (1,0) 
(0,0) (0,0) (1,0) (1,1) (1,1) (0,1) 


any 


(0,0) (0,0) 


2 


(0,1) (0,0) (0,1) (1,1) 


1 


(0,0) (0,1) 




(0,0) (0,1) (1,1) (0,1) 


0 


(0,1) (1,0) 


3 


(1,0) (1,0) (0,0) (1,1) 


1 


(1,0) (0,1) 




(0,0) (1,1) (1,0) (1,0) 


0 


(0,0) (1,0) 


4 


(0,1) 
(0,1) 


any 


(0,1) (0,0) 


5 


(1,0) 
(1,0) 


any 


(1,0) (0,0) 



The addition method according to the present invention shown in Table 4 is 
different from the conventional addition method shown in Table 1 in that a redundant 
binary input (1,1) is also considered, and the values of partial products (<2 ; + ,a~) 

and (b* ,b~) received when h, is 1 are defined differently. That is, in Table 1 

according to the prior art, h, becomes 1 at an input value having a possibility that -1 
is propagated as carry. However, in Table 4 according to the present invention, h s 
becomes 1 at an input value having a possibility that 1 is propagated as carry. The 
role of hj and a method of obtaining an intermediate sum (s* ,s~ ) and an 

intermediate carry (c* ,c~) are the same as those of Table 1 according to the prior 
art, so they will not be described. The sum (d* ,d~ ) of two redundant binary partial 
products (a*,a~) and(Z> + ,ZT) according to Table 4 can be obtained in Equation 
10: 
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= S I ' s j " c ti ' c i-i + S I ' s i c i-\ ' 
k i = (aj © a; ) + • a~ ) + (£ * • 6~ ) 



Equation 10 is embodied in a circuit using the following rule. First, an 
expression for obtaining intermediate parameters /,, h, and k t using input values 
(a* ,a~) and (b* ,b~) is formed of a combination of x* © x~ and jc* • x~ (where 

x is a or jb). Accordingly, as described above, when redundant binary partial 
products are made in FIG. 3, values of Equation 9 obtained by further installation of 
the logic gates 80, 82 and 84 are output to the redundant binary adder 14, instead 
of and d~ being output to the redundant binary adder 14 without change. The 
redundant binary adder 14 using this rule is made up of first through 



iog 2 (M + D 



th redundant binary addition ports (not shown), each of which is 



made up of a predetermined number of redundant binary adders (not shown), each 
of which is embodied with complementary MOS transistors. As described above, 
Table 4 according to the present invention also considers a redundant binary input 
value (1 ,1), thereby reducing the burden on hardware to transform (1,1) into (0,0) as 
in Table 1 . 

The structure and operation of a preferred embodiment of each of the 
redundant binary adders (not shown) according to the present invention will now be 
described referring to FIG. 4. FIG. 4 is a circuit diagram of a simplified adder 
according to a preferred embodiment of the present invention when one among 
partial products to be added is (0,0). This adder includes second and third AND 
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units 90 and 96 and third, fourth, fifth and sixth inversion OR units 92, 94, 98 and 
100. 

In FIG. 4, the third inversion OR unit 92 performs an inversion OR operation 
on the output /, of the second inversion OR unit in the corresponding logic 

combination unit and the previous carry parameter h M and outputs the operation 
result as ft presented in Equation 10. The second AND unit 90 performs AND 
operation on the inputs of the third inversion OR unit 92, and the fourth inversion 
OR unit 94 performs an inversion OR operation on the output of the third inversion 
OR unit 92 and the output of the second AND unit 90 and outputs the operation 
result as a x presented in Equation 10. Here, the fifth inversion OR unit 98 performs 

inversion OR operation on the output of the fourth inversion OR unit 94 and the 
result (3 M of previous inversion-OR operation performed by the third inversion OR 

unit 92 to obtain d* ■ d~ . The third AND unit 96 performs an AND operation on the 

output of the fourth inversion OR unit 94 and the result p M of previous inversion-OR 
operation performed by the third inversion OR unit 92, and the sixth inversion OR 
unit 100 performs an inversion OR operation on the outputs of the fifth inversion OR 

unit 98 and third AND unit 96 to obtain d* © d~ . As described above, in the case 
that a redundant binary input 0, + , a~ ) among redundant binary partial products is 

(0,0), the adder can be simply formed as shown in FIG. 4. 

The structure and operation of an adder according to another preferred 
embodiment of the present invention capable of summing up any types of redundant 
binary numbers will now be described. FIG. 5 is a circuit diagram of an adder 
according to another preferred embodiment of the present invention, which includes 
fourth, fifth and sixth inverters 116, 120 and 122, p-type and n-type MOS transistors 
that constitute a complementary MOS inverter 1 1 8, first, second, third, fourth and 
fifth transmission gates 108, 124, 126, 128 and 130, fourth and fifth AND units 110 
and 134, and seventh, eighth, ninth and tenth inversion OR units 112, 114, 132 and 
136. 
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Referring to FIG. 5, the fourth AND unit 110 performs an AND operation on 
the output a* a~ of the first inversion OR unit in one logic combination unit and the 

outputZ> + b* of the first inversion OR unit in another logic combination unit. The 
seventh inversion OR unit 112 performs an inversion OR operation on the inputs of 
the fourth AND unit 1 10 to obtain h t . The eighth inversion OR unit 114 performs an 
inversion OR operation on the output of the fourth AND unit 110 and the output 
(a, + © a~) of the second inversion OR unit in one logic combination unit to obtain k, . 

Here, the third inverter 116 inverts the output « © a~) of the second inversion OR 
unit in one logic combination unit. The complementary MOS inverter 1 1 8 is 
provided between the output (a* © a~) of the second inversion OR unit in one logic 
combination unit and the output of the third inverter 116, and receives and inverts 
the output (£> + © b~) of the second inversion OR unit in another logic combination 

unit to obtain I,. In response to the output « © «~) of the second inversion OR unit 
in one logic combination unit and the output of the third inverter 116, the first 
transmission gate 108 outputs the input © b~) of the complementary MOS 

inverter 1 1 8 as the input I, of the inverter 120. The fourth inverter 120 inverts and 
output the output of the complementary MOS inverter 118, and the fifth inverter 122 
inverts and outputs the previous output h t _ x of the seventh inversion OR unit 112. 

The second transmission gate 124 transmits the output of the fifth inverter 122 in 
response to the output of the fourth inverter 120 and the output !j of the 
complementary MOS inverter 118. The third transmission gate 126 transmits the 

previous output h t _ x of the seventh inversion OR unit 1 12 in response to the output 

I, of the complementary MOS inverter 118 and the output of the fourth inverter 120. 

The fourth transmission gate 128 transmits the previous output \_ x of the seventh 

inversion OR unit 1 12 in response to the output of the fourth inverter 120 and the 
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output I, of the complementary MOS inverter 118. The fifth transmission gate 130 
transmits the output of the eighth inversion OR unit 1 14 in response to the output I, 
of the complementary MOS inverter 118 and the output of the fourth inverter 120. 
The ninth inversion OR unit 132 performs an inversion OR operation on the outputs 
o7 of the second and third transmission gates 124 and 126 and the previous 

outputs 3 M of the fourth and fifth transmission gates 128 and 130 to obtain ■ d~ . 

Here, the fifth AND unit 134 performs an AND operation on the inputs of the ninth 
inversion AND unit 132, and the tenth inversion OR unit 136 performs an inversion 
OR operation on the output of the fifth AND unit 134 and the output of the ninth 

inversion OR unit 132 to obtain (^ + © d~ ) . 

A digital multiplication method according to the present invention performed 
in the digital multiplication apparatus adopting a redundant binary arithmetic method 
shown in FIG. 1 will now be described with reference to the attached drawings. 

FIG. 6 is a flowchart illustrating a digital multiplication method according to 
the present invention including the step 150 of bit-converting one of two numbers to 
be multiplied, the steps 152 through 156 of obtaining redundant binary partial 
products, and the steps 158 and 160 of obtaining the product of two numbers X and 
Y by summing the redundant binary partial products. 

In this digital multiplication method, first, an m-bit number Y is data-converted 
into data D composed of m/k digits as shown in Equation 6, in step 150. The step 
150 is performed in the data converter 10 shown in FIG. 1 . Next, the fundamental 
multiple determination unit 20 of FIG. 2 determines the coefficients of fundamental 
multiples, in step 152. The step 152 will now be more specified below. 

FIG. 7 is a flowchart for explaining the step 152 of determining the 
coefficients of fundamental multiples shown in FIG. 6. The step 152 includes the 
steps 1 80 and 182 of dividing the bits of one of two numbers to be multiplied and the 
steps 184 and 186 of obtaining the coefficients of a fundamental multiple by 
multiplying divided bits by weighted values. 

After the step 150, the m bits of the number Y are grouped by (k+1 ) bits while 
consecutive groups overlap by one bit, in step 180. Next, the k bits excluding the 
most significant bit are divided into t upper bits and s (^t) lower bits, that is, into (t.s), 
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in step 182. Here, k is equal to s+t. After the step 1 82, an s-bit group value is 
obtained by multiplying each of the s lower bits by a corresponding weighted value 
among weighted values and summing the products, in step 184. Then, a t-bit group 
value is obtained by multiplying each of the t upper bits by a corresponding 
weighted value among weighted values, summing the products, and multiplying the 
sum by 2 s , in step 1 86. Here, the coefficients of a fundamental multiple are 
determined from the s-bit group value and the t-bit group value. The step 1 86 can 
be performed prior to the step 1 84. 

A method of determining the coefficients of a fundamental multiple in the case 
of a radix-2 k , according to a preferred embodiment of the present invention, will now 
be described with reference to the attached drawings. 

FIG. 8 is a flowchart for explaining a preferred embodiment of the step 152 
shown in FIG. 6. This embodiment includes the steps 200 through 206 of obtaining 
the coefficients of a fundamental multiple using the lower bits of Yj (which denotes a 
j-th group of (k+1) bits of a multiplier Y) and the steps 208 through 214 of obtaining 
the coefficients of a fundamental multiple using the upper bits of Yj. 

First, it is assumed that the number of lower bits of Y } is s, the number of 



upper bits of Y, is t, k is t+s, and t is — (where L*J denotes an integer that is x or 



the largest one among integers that are smaller than x). That is, t is equal to or 
smaller than s. 

A decimal value s_grp 10 of an s-bit binary number s_grp 2 is initialized, in step 
200. Next, the coefficient value of a fundamental multiple of the decimal value 
s_grp 10 is obtained as shown in Equation 1 1 , in step 202: 



wherein s_grp 2 [i] denotes the i-th bit of s_grp 2 , and FMC denotes an arrangement of 
the coefficients of a fundamental multiple. 

After the step 202, it is determined whether s_grp 10 is smaller than 2 s , in step 
204. If s_grp 10 is not smaller than 2 s , it increases by 1 , in step 206, and the step 202 
is again performed. 




FMC[s_ grp l0 ] = s_ grp 2 [0] + X s - S r Pi U] *2 J ' 



t-i 



(11) 
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On the other hand, if s_grp 10 is smaller than 2 s , a decimal value t_grp 10 of a t- 
bit binary number t_grp 2 is initialized, in step 208. Then, the coefficient of a 
fundamental multiple for the decimal value t_grp 10 is obtained as shown in Equation 
12, in step 210: 

t-\ 

FMC[s_grp l0 + t_grp w ] = V *(t_grp 2 [0]+ £ t_grp 2 [j]*2 J - 1 ) ...(12) 

wherein t_grp 2 [i] denotes the i-th bit of t_grp 2 . 

Thereafter, it is determined whether t_grp 10 is smaller than 2\ in step 212. If 
t_grp 10 is not smaller than 2\ it increases by 1 , in step 214, and the step 210 is 
performed again. On the other hand, if t_grp 10 is smaller than 2\ the step 152 is 
concluded. 

The contents of the FMCs obtained by Equations 1 1 and 12 are the 
coefficients of a fundamental multiple required by 2 k , but the coefficient of the same 
fundamental multiple can be obtained repeatedly several times. 

In order to facilitate understanding of the step 152 of FIG. 6 and the methods 
shown in FIGS. 7 and 8, a method of determining the coefficient of a fundamental 
multiple, according to the present invention, will now be described on the 
assumption that k is 6. 

First, every consecutive 7 bit of the bits of Y are grouped, and consecutive 
groups overlap by one bit such that the last bit of each group is the first bit of the 
following group. The 7-bit groups are re-coded in a radix-64 numeration system, 
thereby resulting in Table 5. That is, Table 5 refers to the case that one of two 
binary input values to be multiplied is re-coded in a radix-64 numeration system, and 
shows conversion of a binary bit group into a radix-64 number. 

In Table 5, a bit y6 determines the sign of n. As can be seen from Equation 
6, two types of Y groups can be obtained for a single n, and some of them must be 
treated differently in order to simplify the construction of a circuit. Thus, the 
differently-treated groups are distinguished from the other groups by box wrapping 
in Table 5. 
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[Table 5] 



y6y5y4y3y2y1y0 


n innX 


y6y5y4y3y2y1y0 


ninnX 


y6y5y4y3y2y1y0 


n in n X 


y6y5y4y3y2y1y0 


n in nX 


0000000 


0 


0011111 




1111111 


0 


1011110 


-17 


0000001 




0100000 


16 


1111110 


-1 


1011101 


0000010 


1 


0100001 


17 


1111101 




1011100 


-18 


0000011 




0100010 


1111100 


-2 


1011011 




00001 00 


2 


0100011 




1111011 


1011010 


-19 


00001 01 




0100100 


18 


1111010 


-3 


101 1001 




00001 10 


3 


0100101 




1111001 


1011000 


-20 


0000111 


4 


0100110 


19 


1111000 


-4 


1010111 


0001 000 


0100111 


20 


1110111 




1010110 


-21 


0001 001 




01 01000 


1110110 


-5 


1010101 


0001 01 0 


5 


0101001 


21 


1110101 


101 0100 


-22 


0001 01 1 




01 01 01 0 


1 1 1 01 00 


-6 


1010011 


0001 1 00 


6 


0101011 


22 


1 1 1 001 1 


101 0010 


-23 


0001 101 


7 


01 01100 


1110010 


-7 


1 01 0001 


nnm 1 1 n 

UVu i 1 1 U 


0101101 


23 


111 0001 


1 01 0000 


-24 


UUU MM 




01 01 1 1 0 


111 0000 


-8 


1 001 1 1 1 




8 


01 01 1 1 1 


24 


1101111 




1 001 1 1 0 


-25 


001 0001 




01 1 0000 


11011 10 


-9 


1001101 


noi nm n 


9 


01 1 0001 


25 


1101 101 




1001 100 


-26 


UU I UU I 1 


10 


0110010 


1101100 


-10 


1 001 01 1 


001 01 00 


01 1 001 1 


26 


1101011 


1001010 


-27 


00101 01 


11 


01 10100 


1101010 


-11 


1001001 


nm en 1 n 
uu i u m u 


01101 01 


27 


1 1 01 001 




1001 000 


-28 


001 01 1 1 




01 101 1 0 


1 1 01 000 


-12 


1 0001 1 1 




001 1 000 


12 


0110111 




1100111 




1000110 


-29 


0011001 




0111000 


28 


1100110 




1000101 


0011010 


13 


0111001 




1100101 


-13 


1000100 


-30 


0011011 




0111010 


29 


1100100 


--4 


1000011 




001 11 03 


14 


0111011 




1100011 




1000010 


-31 


001 1 1 01 




0111100 


30 


1100010 




1 000001 




0011110 


15 


0111101 




1100001 


-15 


1000000 


-32 






0111110 


31 


1100000 


-16 










0111111 


32 | 1011111 









The bits of Yj excluding the most significant bit y6 are divided into (t,s), which 
is (3 bits, 3 bits). Here, in order to obtain each group value, a weighted value for 
each bit is set to be, for example, 1 , 1 , 2, 4, 8, ... , 2\ starting from the least 
significant digit. If k is 6, there are weighted values of 1 , 1 and 2. If the bits of an s- 
bit group is '101, an S-bit group value is 3 by the calculation of 2-1 +1-0+1-1. Since 
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the digits of a t-bit group are higher than those of an s-bit group, an appropriate 
weighted value must be multiplied. Thus, the number obtained from the t-bit group 
is multiplied by 2 s . That is, if the t-bit group is '1 01', a t-bit group value is 24 by the 
calculation of (2- 1 +1 -0+1 • 1 )*2 3 . Bit group values obtained by the above-described 
method are shown in Table 6, and they correspond to n in a fundamental multiple 
nX. 

Table 6 shows bit group values which are required to express many normal 
binary multiples with only several combinations of fundamental multiples. 



[Table 6] 



y6 


s-bit group ( 


8=3) 


s-bit group 
value 


t-bit group (t=3) 


t-bit group 
value 


y5 


V4 


y3 


v2 


yi 


yO 


Don't 


0 


0 


0 


0 


0 


0 


0 


0 


care 


0 


0 


1 


8 


0 


0 


1 


1 




0 


1 


0 


8 


0 


1 


0 


1 




0 


1 


1 


16 


0 


1 


1 


2 




1 


0 


0 


16 


1 


0 


0 


2 




1 


0 


1 


24 


1 


0 


1 


3 




1 


1 


0 


24 


1 


1 


0 


3 




1 


1 


1 


32 


1 


1 


1 


4 



As can be seen from Table 6, there are 9 fundamental multiples of OX, 1X, 
2X, 3X, 4X, 8X, 16X, 24X and 32X. 

Referring back to FIG. 6, after the step 152, the controller 50 receives data D 
from the data converter 10 via an input port IN and converts each of the digits Di of 
the data D into a combination of the coefficients of a fundamental multiple, in step 
154. Next, redundant binary partial products are obtained by multiplying each of the 
converted results by X, in step 156. In order to achieve this, the controller 50 
generates selection signals S1 , S2, ... and Sm/k in accordance with the combination 
of coefficients of a fundamental multiple to allow multiplexers to select the products 
of combinations of the coefficients of a fundamental multiple by X. After the step 
156, the redundant binary adder 14 sums redundant binary partial products, in step 
1 58. Then, a final result of multiplication of two numbers X and Y is obtained by 
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converting the sum having a redundant binary form into a normal binary number, in 
step 160. 

Assuming that k is 6, the step of converting a normal binary partial product of 
a multiplicand X by a coded multiplier Y into a redundant binary partial product of 
the combination of fundamental multiples, in a digital multiplication method adopting 
a redundant binary arithmetic, according to a preferred embodiment of the present 
invention, will now be described with reference to the attached drawings. 

FIG. 9 is a flowchart illustrating a preferred embodiment of the steps 152 
through 156 shown in FIG. 6 in a digital multiplication method adopting a redundant 
binary arithmetic, according to the present invention. This embodiment is made up 
of the steps 240 through 250 of determining the coefficients of a fundamental 
multiple and the step of 252 through 268 of obtaining a redundant binary partial 
product (A,B) and correction bits (EX\EX~). Here, (A,B) is an expression of the 
normal binary partial product of a coded Yj by X in a redundant binary number. 

Referring to FIG. 9, the coefficients of a fundamental multiple are determined 
through the steps 240 through 250 described below. First, it is determined whether 
the most significant bit (MSB), which is the sign bit, of Yj is 1 , in step 240. If the 
most significant bit (MSB) of Yj is 1 , each of the bits of Yj is inverted, in step 242. 
On the other hand, if the most significant bit (MSB) of Yj is not 1 , it is also 
determined whether the fourth bit l A from the least significant bit of Yj is 1 , in the step 
244. The step 244 is also performed after the step 242. If the fourth bit l A from the 
least significant bit of Yj is 1 , each of the s lower bits of Y, is inverted, in step 246. 
Thereafter, an s-bit group value is obtained by multiplying each of the s lower bits of 
Yj by a corresponding weighted value and summing the products, and a t-bit group 
value is obtained by multiplying each of the t upper bits of Yj by a corresponding 
weighted value and multiplying the products by 2 3 (=8), in step 250. 

Next, a redundant binary partial product (A,B) and correction bits (EX + ,EX~) 
are obtained in the steps 252 through 268. To be more specific, after the step 250, 
it is determined whether l A is "1", in step 252. If l A is "1", value A is obtained by 
multiplying the s-bit group value by X and inverting the product, in step 254. On the 
other hand, if l A is not "1", value A is obtained by multiplying the s-bit group value by 
X, in step 256. After the step 254 or 256, value B is obtained by multiplying the t-bit 
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group value by X and inverting the product, in step 258. Then, it is determined 
whether l A is "1", in step 260. If ! A is "1", the correction bits (EX + ,EX ) are set to be 
(0, 0), in step 262. On the other hand, if l A is not "1", the correction bits (EX + ,EX~) 
are set to be (0,1 ), in step 264. After the step 262 or 264, it is determined whether 
the most significant bit of Yj, which is the sign bit, is "1 ", in step 266. If the most 
significant bit of Yj is "1", the positions of A and B in (A,B) are transposed, and the 
positions of EX + and EX in (EX + ,EX~) are transposed, in step 268. On the other 
hand, if the most significant bit of Yj is not "1 ", or after the step 268, the step 1 58 of 
FIG. 6 is performed. 

Consequently, in the present invention, in case that a partial product is one of 
odd multiples of X, for example, 27X, 27X is obtained from a combination of 
fundamental multiples 3Y and 24Y, such as 3X+24X. Thus, the addition of two 
normal binary numbers can be easily achieved by a conversion into a redundant 
binary number, and this conversion puts little burden on hardware. That is, several 
odd multiples required for multiplication can be expressed in combinations of 
fundamental multiples, the number of which is smaller than the number of odd 
multiples. 

As described above, a digital multiplication apparatus and method adopting a 
redundant binary arithmetic, according to the present invention, can greatly reduce 
the burden on hardware by expressing the multiples of X in a redundant binary 
number rather than a normal binary number by applying the redundant binary 
number concept to produce a partial product. Even when the radix which is used to 
make a partial product extends to 4 of the widely-used MBA or greater, the burden 
upon hardware can be minimized. Since the radix increases and thus the number of 
partial products is reduced, the volume of hardware for summing partial products 
can also be reduced. Furthermore, the structure of a redundant binary adder for 
summing partial products is improved as shown in FIGS. 4 and 5, thereby optimizing 
a multiplication method. Therefore, many systems having multipliers serving as an 
important component can be more simply constructed. 
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